package cn.iocoder.yudao.module.product.sku.dal.dataobject;

import cn.iocoder.yudao.framework.business.basic.pojo.po.MerchantScopeEntity;
import cn.iocoder.yudao.module.api.product.sku.dto.ProductPropertyValueRespDTO;
import cn.iocoder.yudao.module.product.spu.dal.dataobject.ProductSpuDO;
import com.baomidou.mybatisplus.annotation.KeySequence;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.util.List;

/**
 * 产品 SKU
 * TODO 后续重构，产品中心的产品表只存储通用的基础的数据，商城/酒店/家政/景区等不同模块的产品扩展数据放在各自模块
 *
 * @author 芋道源码
 */
@TableName(value = "product_sku", autoResultMap = true)
@KeySequence("product_sku_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库，可不写。
@Data
@NoArgsConstructor
@AllArgsConstructor
public class ProductSkuDO extends MerchantScopeEntity {

    /**
     * SPU 编号
     * <p>
     * 关联 {@link ProductSpuDO#getId()}
     */
    private Long spuId;
    /**
     * 属性数组，JSON 格式
     */
    @TableField(typeHandler = JacksonTypeHandler.class)
    private List<ProductPropertyValueRespDTO> properties;
    /**
     * 销售价，单位：分。如果是零售商家产品，则为零售价；如果是厂家产品，则为批发价。
     */
    private Integer price;
    /**
     * 成本价，单位：分
     */
    private Integer costPrice;
    /**
     * 市场价，单位：分
     */
    private Integer marketPrice;
    /**
     * 会员价，单位：分
     */
    private Integer vipPrice;
    /**
     * 厂家零售价，单位：分。如果填写了则支持零售，不填则只支持批发。
     */
    @TableField(value = "wholesale_price")
    private Integer wholesaleForRetailPrice;
    /**
     * 产品条码
     */
    private String barCode;
    /**
     * 图片地址
     */
    private String picUrl;
    /**
     * 库存
     */
    private Integer stock;
    /**
     * 产品重量，单位：kg 千克
     */
    private Double weight;
    /**
     * 产品体积，单位：m^3 平米
     */
    private Double volume;

    /**
     * 一级分销的佣金(单位：分)
     *
     * @deprecated 这个字段，应该后续重构移到分销商品表中
     */
    @Deprecated
    private Integer firstBrokeragePrice;
    /**
     * 二级分销的佣金(单位：分)
     *
     * @deprecated 这个字段，应该后续重构移到分销商品表中
     */
    @Deprecated
    private Integer secondBrokeragePrice;

    /**
     * 产品销量
     */
    private Integer salesCount;

    /**
     * 供应方名称
     */
    private String supplyName;
    /**
     * 供应方关联编号
     */
    private Long supplyRelatedId;

}

